у ш-уведомле ей ЕН $1 кот ге: _ 
ь ‘ак мы сделалих "ВОЙ транспорт 


| аз а М е Н ут у.) 09 | ыы ге р азе. 


| | 
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] 
ИГ 
ИТ | | 
ИТ ] | ] 


Обо мне 


Обо мне 


Окончил бакалавриат 
и магистратуру факультета 
ВМК МГУ 


(но) ННЕоаа"" 


Обо мне 


Окончил бакалавриат 
и магистратуру факультета 
ВМК МГУ 


В \УК руковожу несколькими 
командами разработки бэкенда 
в «Почте Май.ги» 


Обо мне 


Окончил бакалавриат 
и магистратуру факультета 
ВМК МГУ 


—_ ВУК руковожу несколькими 


командами разработки бэкенда 
в «Почте Май.ги» 


Играю на гитаре и планирую 
спринты в «Дела Поважнее» 


Кизоге развивается 
при содействии 
крупнейших российских 


Т-компаний Яндекс 
Организационная и методическая | 
поддержка со стороны Совета 

при Министерстве цифрового развития охом 


Спасибо 


за ваши 
контакты! 
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©® 

Введение 
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Обзор публичной Как устроены наши 
части сервиса мобильные 50К 
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о 

Введение 

® о о 

Обзор публичной Как устроены наши Детали архитектуры 
части сервиса мобильные ОК бэкенда сервиса пушей 
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Содержание Й 


® 
Введение 


® о о 
Обзор публичной Как устроены наши Детали архитектуры 
части сервиса мобильные ОК бэкенда сервиса пушей 


Почему мы 
не ляжем (надолго) 


(но) ННЕоаа"" 


Содержание Й 


о 
Введение 
о о о 
Обзор публичной Как устроены наши Детали архитектуры 
части сервиса мобильные 50К бэкенда сервиса пушей 
® @ 
Почему мы Как мы интегрировали 
не ляжем (надолго) пуши Ки юге в Почту 
Май.ги (и что из этого 
вышло) 


(но) ННГоаа"" 


[уп Ки$оге Введен ие 


Зачем делать 
свой транспорт пушей АррИсаНоп Васкепа 


Арре Ри$п АР! Сооде Риз АР! 


Ю5$ БВемсе 05$ Ремсе Апагоа Ремсе Апагоа Оемсе 


НЕ) ННГоаа"" 


Зачем делать 
свой транспорт пушей АррИсаНоп Васкепа 


Пуши отправляются через 
АР! Соо!е/Арр!е/Ниаме!, @с 


Арре Ри$п АР! Сооде Риз АР! 


| | 
О 


Ю5$ Вещмсе Ю$ Вещмсе Апагоа Ремсе Апагоа Оемсе 


НЕ) ННГоаа"" 


Зачем делать 
свой транспорт пушей 


Пуши отправляются через 
АР! Соое/Арр!е/Ниаме!, @с 


Если Сооде решит, 
что Почте больше не нужны 
пуши, то у нас лапки 


| 


_ 


Ю5$ Вещмсе 


Арре Ри$п АР! 


АррИсаНоп Васкепа 


| 
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Ю$ Вещмсе 


—. 


Апагоа Ремсе 


Сооде Риз АР! 


Апагоа Оемсе 


НЕ) ННГоаа 


Зачем делать 
свой транспорт пушей 


Пуши отправляются через 
АР! Соое/Арр!е/Ниаме!, @с 


Если Сооде решит, 
что Почте больше не нужны 
пуши, то у нас лапки 


_ 


Ю5$ Вещмсе 


АррИсаНоп Васкепа 


_ 


Ю$ Вещмсе 


Сооде Ризп АР! 


—. 


Апаго Ремсе 


Апагоа Оемсе 


НЕ) НЕНГоаа 


Зачем делать 
свой транспорт пушей 


Пуши отправляются через 
АР! Соое/Арр!е/Ниаме!, @с 


Если Сооде решит, 
что Почте больше не нужны 
пуши, то у нас лапки 


Разработчики запретили уведомления на 


предыдущей версии. 

Уведомления о новой почте не приходят, 
можно узнать только если открыть 
приложение. 


| 


_ 


Ю5$ Вещмсе 


Арре Ри$п АР! 


АррИсаНоп Васкепа 


| 


_ 


Ю$ Вещмсе 


—. 


Апаго Ремсе 


Сооде РизП АР! 


—. 


Апагоа Бемсе 
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Требования 
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от пушей 
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на устройство 
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© 

Возможность отправлять 
пуши по заданному токену 
с мгновенной доставкой 
на устройство 


Временное хранение 
пушей, пока устройство 
в о_Нше (с ТТЕ.) 


фе 


Требования 
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и отписываться 
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© 

Возможность отправлять 
пуши по заданному токену 
с мгновенной доставкой 
на устройство 


о 

Временное хранение 
пушей, пока устройство 
в о_Нше (с ТТЕ.) 
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Требования 
к сервису 
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и отписываться 
от пушей 
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© 

Возможность отправлять 
пуши по заданному токену 
с мгновенной доставкой 
на устройство 


© 
Сервис должен 
быть безопасным 


о 

Временное хранение 
пушей, пока устройство 
в о_Нше (с ТТЕ.) 


(но) ННГоаа"" 


Требования 
к сервису 


® 

Возможность 
подписываться 
и отписываться 
от пушей 


® 
Сервис должен 
быть надежным 


© 

Возможность отправлять 
пуши по заданному токену 
с мгновенной доставкой 
на устройство 


© 
Сервис должен 
быть безопасным 


о 

Временное хранение 
пушей, пока устройство 
в о_Нше (с ТТЕ.) 


о 

Простая интеграция 
в текущую схему 
работы с пушами 


(но) ННГоаа"" 


Как выглядит любой 
пуш-сервис 


(55 


НЕ) ННГоаа"" 


Как выглядит любой 
пуш-сервис 


Ф® 


® 

Пуш-токен 
идентифицирует 
приложение на 
конкретном устройстве 


"фокеп": "РЕСбУСОВТСР7ез Ц ОРУЗУТ1\У8аРСУааЕВЬ" , 
"{161е": "Клг111 АТек$ееу\пТИ1$ 1$ а ризй {111е", 
"роду": "ТР1$ 15 а ризй Боау", 


"соте_о{Пег_и5ефи1Т _Чафа": "42" 


НЕ) ННГоаа 


Как выглядит любой 


Фо 


пуш-сервис 

® о 

Пуш-токен В пуше можно послать 
идентифицирует произвольный пэйлоад 
приложение на и обработать его 
конкретном устройстве на клиенте 


"фокеп": "РЕСУСОВТСР7ез ЦОРУЗУТ1\/8аРбУачеЕВЬ" , 
"{161е": "Клг111 АТек$ееу\пТИ1$ 1$ а ризй {111е", 


и. Кий! А!еК$ее\у 
"роду": "ТИ1$ 15$ а ризй Боау", 


ТЬ$ 1$ а рип {е 
ТЬ5$ 15 а ризВ БоЧу 


"соте_о{Пег_и5ефи1Т _Чафа": "42" 


фе 


Как выглядит любой 


Фо 


пуш-сервис 

® о ©® 

Пуш-токен В пуше можно послать Встроенные транспорты 
идентифицирует произвольный пэйлоад пушей используют 
приложение на и обработать его недоступные нам 
конкретном устройстве на клиенте механизмы ОС 


и устройства 


"фокеп": "РЕСУСОВТСР7ез ЦОРУЗУТ1\/8аРбУачеЕВЬ" , 
"{161е": "Клг111 АТек$ееу\пТИ1$ 1$ а ризй {111е", 


а Кий АеК$ее\у сейчас 
"роду": "ТР1$ 15$ а ризй роду", 


ТЬ$ 1$ а ри$В {Ше 
ТЬ5$ 15 а ризВ БоЧу 


"соте_о{Пег_и5ефи1Т _Чафа": "42" 


фе 


Обзор 
[ гзюе —————— Публичной 
части сервиса 


Веб-интерфейс управления 
пушами приложения в Ки {оге 


< Кприложениям 


Маруся 


С} Версии 
8% Доступы 
О отзывы 


^7 Статистика 
по приложению 


«9 Продвижение 
> Монетизация 


у Ризв-уведомления 


$ Проекты 


ВЕТА 


ВЕТА 


@) РизВ-уведомления работают в режиме тестирования. Если возник 
Проекты / 


П РОД во 


1Ю проекта 


а\$13]5\№а38у03 О 


Отпечаток подписи ЗНА-256 
91:АС:ЗЕ:2Е:СВ:С2:42:87:6А:85:02:86:ЕВ:44:84:10:34:02:Е0:35:СЕ:С6:38:47:Е 
Е:50:07:28В:Е0:09:80:8В 


Сервисные токены Создано: 2/5 — -- Создать 


% 1409-лоМме ГС) м 


3? 1.4090г3226 Г) ® 


Веб-интерфейс управления 
пушами приложения в Ки {оге 


< Кприложениям р Приложение 
идентифицируется 
м - ыы 10 проекта 
Прод вос 
С} Версии 
2% Доступы 10 проекта 


а\$13]5\№а38у03 О 


О отзывы 


^7 Статистика 
по приложению Отпечаток подписи ЗНА-256 
91:АС:3Е:2Е:СВ:С2:42:87:6А:85:02:86:ЕВ:44:84:10:34:02:Е0:35:СЕ:С6:38:47:Е 


< Продвижение [:50:07:28В:Е0:09:80:8В 


> Монетизация ВЕТА 
Сервисные токены Создано: 2/5 -- Создать 

у РизП-уведомления ВЕТА 
$Ф Проекты ® 1409ломме О м 


НЕ.) ННГоаа"" 


3?  г.4090г3226 С) е 


Веб-интерфейс управления 
пушами приложения в Ки {оге 


< Кприложениям 


Маруся 


С} Версии 
2> Доступы 
О отзывы 


^” Статистика 
по приложению 


«9 Продвижение 


> Монетизация 


у Ризп-уведомления 


$ Проекты 


ВЕТА 


ВЕТА 


@) РизВ-уведомления работают в режиме тестирования. Если возник 


Проекты / 


П РОД гк 


1Ю проекта 


а\з13/6\м/а38у03 О 


Отпечаток подписи ЗНА-256 
91:АС:3Е:2Е:СВ:С2:42:87:6А:85:02:86:ЕВ:44:84:10:34:02:Е0:35:СЕ:С6:38:47:Е 
Е:50:07:28В:ЕО:09:80:8В 


Сервисные токены Создано: 2/5 -- Создать 


® 1409-лоМме} Г) 


г 40910г3226 Г) 


Приложение 
идентифицируется 
10 проекта 


Сервисные токены 
нужны для авторизации 
на отправке пуша 

и являются 
сенситивными 


НЕ) НЕНГоаа 


Веб-интерфейс управления 
пушами приложения в Ки {оге 


< к ке ©) РизН-уведомления работают в режиме тестирования. Если возникли труд! 


ы 
Ш ““аруся Проекты 
С Версии 
Название 1 10 проекта (1) 
2> Доступы 
Дев 2452655701032 Г) 
О отзывы 
27 Статистика Прод  Рвоо а\$#3/6\№ма38у03 (Г) 


по приложению 


99 Продвижение Тест 1 г4090 мел 0г32 Г) 
> Монетизация ВЕТА 
у Ризп-уведомления ВЕТА 

$Ф Проекты 


Веб-интерфейс управления 
пушами приложения в Ки {оге 


Можно разделить дев- 


< Кприложениям 


ИИА ИИ ИЕ ИИЕНКНИЕ и прод-сервисные 
в токены, привязав к 
в Проекты одному приложению 
— | несколько проектов 
26 Дстиь Баны мы пушей 
Е Дев 2452655701032 Г) 
2^ Статистика Прод  Рвор ауз!3]5Мма38у03 © 
ты 

<@ Продвижение Тест 1 г409 0 мел0г32 Г) 


> Монетизация ВЕТА 
у РизВ-уведомления ВЕТА 
$Ф Проекты 


НЕ) ННГоаа"" 


ЗОК для пуш-сервиса а] 
в Ки оге 


НЕ) ННГоаа"" 


ЗОК для пуш-сервиса 
в Ки оге 


Стараемся быть 
Агор-т герасетег: 
для ЗОК ЕСМ 


НЕ) НЕНГоаа 


ЗОК для пуш-сервиса 


в Кизоге 

® ® 

Стараемся быть Метод де Токеп 
агор-т герасетеги регистрирует и отдает 
для ЗОК ЕСМ приложению новый 


пуш-токен 


ЗОК для пуш-сервиса 


в КиЗоге 

® ® 

Стараемся быть Метод де Токеп 

агор-т герасетеги регистрирует и отдает 

для ЗОК ЕСМ приложению новый 
пуш-токен 

® 

Метод аещеТокКеп 

инвалидирует 

существующий 

токен 


фене 


ЗОК для пуш-сервиса 


в КиЗфоге 

© < 

Стараемся быть Метод де{Токеп 

агор-т герасетеги регистрирует и отдает 

для ОК ЕСМ приложению новый 
пуш-токен 

о ® 

Метод аещеТокКеп Можно определить колбэки 

инвалидирует опМеззадеКесемесч, 

существующий опМем/ТокКеп, 

токен опрееяМе$задез 


фе 


Методы АР! пуш-сервиса Ки оге 


сигТ --ХРОЗТ 'ПЕЕр$: //уКрп$ . гизфоге . ги/\у1 /рго] ест $ /адм1 Каа$ /меззазе$ : зепа' \ 
--Пеадег 'АцтПогтха{1оп: Веагег Чазм1Ка$' --Пеадег 'Сопфепт-Туре: арр11сафтоп/]5о0оп' \ 


--Дафа-гам '{"теззазе" : { 


"токеп" : "РЕСУСОВТСР7ез Ц ОРУЗУТ1\У8аРСЦачевв" , 
"апаго1а":{ "по{1Т1саттоп":{ "11 е": "Не1ТТо, мог1а!"} } 


}}' 


НЕ) НЕНГоаа 


Методы АР! пуш-сервиса Ки оге 


Стараемся быть 
Агор-шт герасетег 
для АР! ЕСМ 


сигТ --ХРОЗТ 'ПЕЕр$: //уКрп$ . гизфоге . ги/\у1 /рго] ест $ /адм1 Каа$ /меззазе$ : зепа' \ 


--Пеадег 'АцтПогтха{1оп: Веагег Чазм1Ка$' --Пеадег 'Сопфепт-Туре: арр11сафтоп/]5о0оп' \ 
--Дафа-гам '{"теззазе" : { 

"тоКеп" : "РЕСУСОВТСР7ез Ц 0ОЕРУИЗУТ1 М8 аРСУАЯЧЕВЬ", 

"апагота":{ "по{1Т1сафтоп":{ "{1{1е": "Не11о, мог1а!"} } 


}}' 


НЕ) НЕНГоаа 


Методы АР! пуш-сервиса Ки оге 


® © 

Стараемся быть Поддерживаем 

Агор-шт герасетег и поНйсайоп, и ааа-пуши, 
для АРГЕСМ но пока что ограниченный 


набор полей 


сигТ --ХРОЗТ 'ПЕЕр$: //уКрп$ . гизфоге . ги/\у1 /рго] ест $ /адм1 Каа$ /меззазе$ : зепа' \ 


--Пеадег 'АцтПогтха{1оп: Веагег Чазм1Ка$' --Пеадег 'Сопфепт-Туре: арр11сафтоп/]5о0оп' \ 


--Дафа-гам '{"теззазе" : { 
"токеп" : "РЕСУСОВТСР7ез Ц ОРУЗУТ1\У8аРСЦачевв" , 
"апагота":{ "по{1Т1сафтоп":{ "{1{1е": "Не11о, мог1а!"} } 


}}' 


Как 
Ш в5юе ———— устроены наши 
публичные $0К 


Основные 
компоненты ОК 


НЕ) ННГоаа"" 


Основные 
компоненты ОК 


Есть два ЗОК: 
«клиентское» 
и «хостовое» 


НЕ) НЕНГоаа"" 


Основные 
компоненты ОК 


® о 

Есть два З0К: «Хостовое» встроено 
«клиентское» в КиЗ{оге и собирает 
и «хостовое» все пуши 


(но) ННЕоаа"" 


Основные 
компоненты ОК 


® о 

Есть два З0К: «Хостовое» встроено 
«клиентское» в КиЗ{оге и собирает 
и «хостовое» все пуши 


® 

«Клиентское» должен 
интегрировать себе 
разработчик приложения 
(аналог ОК Егеразе) 


фе 


Как ОК 


получает пуши те 


Основная масса пушей о 

приходит мгновенно через т 
\\ебЗоскеф, но периодически 
производится НТТР-поллинг 
для доставки затерявшихся. 


| | 

| 

| ризН(Кеп: фокеп_1, зуп: 3} {$ 0$ 
| 


| 
| деокеп: фокеп 1, пуп: 2} 
[ 


| ризВ(окКеп: +оКеп 1, эуп: 3} 


Получение 
пушей в фоне 


Для мгновенной доставки 
пушей нужно разрешение 
от пользователя 


Разрешить приложению запуск в 
фоновом режиме? 


Если приложению "ВиЗоге" будет | 
разрешено всегда работать в 
фоновом режиме, батарея может 
разряжаться быстрее. 


Отозвать разрешение можно в 
любое время. Для этого выберите 
"Настройки > Приложения". 


Отклонить Разрешить 


НЕ) НЕНГоаа 


Детали 

@ гизюе архитектуры 
бэкенда 
сервиса пушей 


Основные 
компоненты 


бэкенда 
Ргоадис* Ме а 
(Кеа!5 Сизтег) 


Соапд АР! в К8$ 
Вед! Сизег 


эсупа Токеп $*огаде 
(Кез Си$ег) 


Кае ИтК$ 
(Кеа$ Си$ег) 
Риб/5иб 
(МоЧйег) 


Риз Зогаде 
(5сУПа) 


НЕ) НЕНГоаа 


Обзор хранилища пуш-токенов й 


НЕ) ННГоаа"" 


Обзор хранилища пуш-токенов 


Исе{а11 токКеп: {888 3ХУХгмСУВ9хЕОто2ТК-и2М} 
1) "рго]есе_1а" 
2) "ЭТЕг1$\/Т$МТЕс00]Е4<16.)Узууб9АС$4" 


3) "уп" 
"145" 
"суп_5{огеЧ" 
"145" 


НЕ) НЕНГоаа 


Обзор хранилища пуш-токенов 


Хранится в Кед!$ 


Сиег Пзефа11 фокКеп: {8В83ХУХгтСУВ9хЕОто71К-и7М} 


"рго]ес&_1а" 
"ЭТЕг15/Т5МТЕс00] Е4 < 16.) Узууб9АС54" 


уп 
"145" 


"зуп_5фогеа" 
“145" 


НЕ) НЕНГоаа 


Обзор хранилища пуш-токенов 


Хранится в Кед!$ 


Сизег Исе{а11 токКеп: {888 3ХУХгмСУВ9хЕОто2ТК-и2М} 
1) "рго]есе_та" 

ЗУМ — монотонно 2) "ЭТ г15\/Т5МТЕс00] Е4 с 16.) Узууб9АС54" 

возрастающий счетчик "суп" 

пушеи до" 


"суп_5{огеЧ" 
“145" 


НЕ) НЕНГоаа 


Обзор хранилища пуш-токенов 


Хранится в Кед!$ 
Сиуег 


$\УМ — монотонно 
возрастающий счетчик 
пушей 


На 1 млн токенов 
требует меньше 
400 МБ 


Исе{а11 токКеп: {888 3ХУХгмСУВ9хЕОто2ТК-и2М} 
1) "рго]есе_1а" 
2) "ЭТЕг1$\/Т$МТЕс00]Е4<16.)Узууб9АС$4" 


уп 
"145" 


"зуп_5фогеа" 
“145" 


(но) НЕНГоаа** 


Обзор хранилища пушей 


НЕ) ННГоаа"" 


Обзор хранилища пушей Ра 


СКЕАТЕ ТАВЕЕ уКрп$.ризй ( 
фокеп_14 Ттехф, 
суп БТЕТПЕ, 
рау1оаа техф, 
{1тезфатр {1тез{фатр, 


Хранится в 5суЙа 
на диске 


РКТМАКУ КЕУ (фоКеп_1а, зуп) 
) МТТН СЕУУТЕВТМ№с ОКОЕК ВУ (зуп АЗС) 
АМ БТоом_Т11Т%ег_Тр_спапсе = 9.01 
АМО сотрасфтоп = {'с1а55': '512еТ1тегеаСотрас топ {гатеуу '} 
АМБ сотрге$$1оп = {'55{аб1е_сотргез1оп': ‘[74Сотргеззог'}; 


(но) ННЕоаа"" 


Обзор хранилища пушей 7% 


СКЕАТЕ ТАВЕЕ уКрп$.ризй ( 
фокеп_14 Ттехф, 
суп БТЕТПЕ, 
рау1оаа техф, 
{1тезфатр {1тез{фатр, 
РКТМАКУ КЕУ (фоКеп_1а, зуп) 


Хранится в 5суЙа 
на диске 


) МТТН СЕУУТЕВТМ№с ОКОЕК ВУ (зуп АЗС) 
АМ БТоом_Т11Т%ег_Тр_спапсе = 9.01 
АМО сотрасфтоп = {'с1а55': '512еТ1тегеаСотрас топ {гатеуу '} 
АМБ сотрге$$1оп = {'55{аб1е_сотргез1оп': ‘[74Сотргеззог'}; 


(уп: 1, рауюаа: {...}, {5: 1667753300) 
(уп: 2, рауюаа: {...}, {$:1667753407) 
(уп: 3, рауюаа: {...}, {5:1667753412) 
(зуп: 4, рауюаа: {...}, {$:1667753417) 
(уп: 5, рауюаа: {...}, 15: 1667753421) 


{океп_1а: 
ЗВ83ХУХитОтогик-ий М 


НЕ) ННГоаа 


Обзор хранилища пушей 7% 


СКЕАТЕ ТАВЕЕ уКрп$.ризй ( 
фокеп_14 Ттехф, 
уп БТЕТПЕ, 
рау1оаа техф, 
{1тезфатр {1тез{фатр, 


Хранится в 5суЙа 
на диске 


Позволяет эффективно 
РЕТМАВУ КЕУ (+0Кеп_14, $уп) 


п ) МТТН СЕУУТЕВТМ№с ОКОЕК ВУ (зуп АЗС) 
и АМ БТоом_Т11%ег_Тр_спапсе = 9.01 
АМБ сотрасф{1оп = {'с1а$5': '517еТ1егеаСотрас&1оп-{гатебу ' } 
АМБ сотрге$$1оп = {'55{аб1е_сотргез1оп': ‘[74Сотргеззог'}; 


зуп: 1, рауоаа: {...}, {5: 1667753300) 
суп: 2, рауюаа: {...}, {5:1667753407) 


( 
т 
Кокеп_1а: (уп: 3, рауюас {..}, 15:1667753412) 
( 
( 


В8ЗХУХ КУЙМ 
ЩЕ. зуп: 4, рауюаа: {...}, {5:1667753417) 


суп: 5, рауоаа: {...}, 15: 1667753421) 


НЕ) ННГоаа 


Обзор хранилища пушей 7% 


СКЕАТЕ ТАВЕЕ уКрп$.ризй ( 
фокеп_14 Ттехф, 
уп БТЕТПЕ, 
рау1оаа техф, 
{1тезфатр {1тез{фатр, 


Хранится в 5суЙа 
на диске 


Позволяет эффективно 
делать чтения 
по океп+зуп_гапде 


РКТМАКУ КЕУ (тоКеп_14, $уп) 
) МТТН СЕУЪТЕКТМ№6 ОКБЕК ВУ (зуп АЗС) 

АМ БТоом_Т11%ег_Тр_спапсе = 9.01 

АМО сотрасфтоп = {'с1а55': '512еТ1тегеаСотрас топ {гатеяу '} 
[МАА/ (Еаз{ \М/Же \МЛпз) А№О сотрге$$1оп = {'$5{а6б1е_сотрге$$1оп': ‘[74Сотргеззог'}; 
спасает от дубликатов 
пушей 


зуп: 1, рауоаа: {...}, {5: 1667753300) 
суп: 2, рауюаа: {...}, {5:1667753407) 


( 
т 
Кокеп_1а: (уп: 3, рауюас {..}, 15:1667753412) 
( 
( 


В8ЗХУХ КУЙМ 
ЩЕ. зуп: 4, рауюаа: {...}, {5:1667753417) 


суп: 5, рауоаа: {...}, 15: 1667753421) 


НЕ) ННГоаа 


Логика в АР! на отправке пуша 


сигТ --ХРОЗТ 'ПЕЁрэ: //уКрп$ . гизфоге .ги/\1 /рго] ест$ / аат1Кда$ /тмеззазез : зепа' \ 
- -Пеааег 'Ацтпогтхаттоп: Веагег дазм1Кад$' --Пеааег 'Сопфеп{-Туре: арр11саф1топ/]зо0оп' \ 
--Дафа-гам '{"тез5аде" : { 


"сокет" : "РЕСУСОВТСРез Ц ОРУЗУТ1\М8 аРрСУааеЕВЬ", 
"апагота":{ "по{1Т1тсаттоп" :{ "фе": "Не11о, мог1Та!"} } 


р. 


НЕ) ННГоаа 


Логика в АР! на отправке пуша 


оО Рго]ес{ Зогаде 
| | 


| спеск$2$ТокепРогРгоес((ргоес9Ю, $2$Токеп) | 


Токеп Зюгаде 


Логика в АР! на отправке пуша 


РизВ $огаде 


| замеРи$Р\ЛИЕНТ ТЕ(океп, ризв, |) | 
о 


НЕ) ННГоаа"" 


Логика в АР! на получении пуша 


сиг 'ПЕфр$: //уКкрп$.гизфоге. ги/\у1 /рго] ес$/меззазе$ : зеф' -Н'Сопфепт-Туре: 
арр11сае1оп/ ] 5оп' \ 
- -афа-гам '{ "гедие${$": [ 


{ 


"рго] ест 14а": "аам1ТКаа$", "мтп_зуп": 12, "11м1е": 10, 
"Токеп": "РЕСИСОВЕСР7ез ЦОРУЗУТ1\/8аРСУааЕВЬ" 


НЕ) НЕНГоаа 


Логика в АР! на получении пуша 


@® Токеп $+огаде РизВ Зогаде 


КазРизпез\М5упСТ(ризН Токеп, птбуп) 


Как не забить хранилище 
неактуальными пуш-токенами 


НЕ) ННГоаа"" 


Как не забить хранилище 
неактуальными пуш-токенами 


Причины появления 
протухшего токена: 


НЕ) ННГоаа"" 


Как не забить хранилище 
неактуальными пуш-токенами 


Причины появления 
протухшего токена. 


приложение удалили 


НЕ) ННГоаа 


Как не забить хранилище 
неактуальными пуш-токенами 


Причины появления 
протухшего токена. 


приложение удалили 


телефон потеряли 


НЕ) ННГоаа 


Как не забить хранилище 
неактуальными пуш-токенами 


Причины появления 
протухшего токена. 


приложение удалили 


телефон потеряли 


2??? 


НЕ) ННГоаа 


Как не забить хранилище 
неактуальными пуш-токенами 


@ ® 

Причины появления У всех пуш-токенов есть 

протухшего токена: ТТЕ в хранилище 
токенов 


приложение удалили 


телефон потеряли 


2??? 


НЕ) ННГоаа 


Как не забить хранилище 
неактуальными пуш-токенами 


@ ® 

Причины появления У всех пуш-токенов есть 

протухшего токена: ТТЕ в хранилище 
токенов 


приложение удалили 


телефон потеряли 


2??? 


Автоматически обновляем 
время жизни токена, 

если клиент приходил 

за пушами 


Почему 
Ц гзюе — [= мы не ляжем 
(надолго) 


Отказоустойчивость 
на уровне АР! РиЫс МР 


АР! живет в кубере 
Кубер живет в 5 ДЦ 


Настроены хэлсчеки подов 


НЕ) НЕНГоаа"" 


Кеа!$ СЦизег для хранилища 
пуш-токенов 


НЕ) ННГоаа"" 


Кеа!$ Сизег для хранилища 
пуш-токенов 


Масштабируемся 
горизонтально благодаря: 


НЕ) НЕНГоаа"" 


Кеа!$ Сизег для хранилища 
пуш-токенов 


Масштабируемся 
горизонтально благодаря: 


— автоматическому решардингу 


НЕ) НЕНГоаа"" 


Кеа!$ Сизег для хранилища 
пуш-токенов 


Масштабируемся 
горизонтально благодаря: 


— автоматическому решардингу 


— роутингу чтений на реплики 


НЕ) НЕНГоаа"" 


Кеа!$ Сизег для хранилища 


пуш-токенов 

о © 

Масштабируемся Устойчивы к уходу 
горизонтально благодаря: узла/дата-центра благодаря: 


— автоматическому решардингу 


— роутингу чтений на реплики 


Кеа!$ Сизег для хранилища 


пуш-токенов 


Масштабируемся 
горизонтально благодаря: 


— автоматическому решардингу 


— роутингу чтений на реплики 


о 
Устойчивы к уходу 
узла/дата-центра благодаря: 


— автоматическому фэйловеру 
(с коротким даунтаймом) 


Кеа!$ СЦизег для хранилища 


пуш-токенов 


Масштабируемся 
горизонтально благодаря: 


— автоматическому решардингу 


— роутингу чтений на реплики 


о 
Устойчивы к уходу 
узла/дата-центра благодаря: 


— автоматическому фэйловеру 
(с коротким даунтаймом) 


— ретраям чтений в другую 
реплику 


фе 


эсуПа для хранилища пуш-токенов 


НЕ) ННГоаа"" 


э5суПа для хранилища пуш-токенов 


Масштабируемся 
горизонтально благодаря 
автоматическому 
решардингу 


НЕ) НЕНГоаа 


э5суПа для хранилища пуш-токенов 


о © 

Масштабируемся Устойчивы к уходу узла/ 
горизонтально благодаря дата-центра благодаря 
автоматическому отсутствию ведущих 
решардингу узлов 


фе 


эсуПа для хранилища пуш-токенов 


Масштабируемся 
горизонтально благодаря 
автоматическому 
решардингу 


Устойчивы к уходу узла/ 
дата-центра благодаря 
отсутствию ведущих 
узлов 


® 
Без даунтайма! 


(но) ННЕоаа"" 


Миллион 10 миллионов 
\Меб5оскКе! и Со 


НЕ.) НЕНГоаа"" 


Миллион 10 миллионов 
УММерзоскКе{ и Со 


Сервис успешно 
эксплуатируется в Почте 
Май.ги уже пять лет 


НЕ.) НЕНьоаа** 


Миллион 10 миллионов 
\Меб5оскКе! и Со 


© ® 

Сервис успешно Устойчив к уходу 
эксплуатируется в Почте одного ДЦ 
Май.ги уже пять лет 


(нь) НЕНЕоаа** 


Защита от Оо$ 
на генерации пуш-токенов 


Апагоа $О0К \/КРМ$-Ац{А-Ргоху Киз оге АцВ Ттр Токеп 5$егмсе 
| 


| 
чеЕТтрТокеп(о2-кюкеп, рибкеу, раскаде!а) | | 
| 


спеско2Токеп(о2-{юКеп) 


изепа 


{тпр-®©Кеп 


Защита от оз 
на генерации пуш-токенов 


Апагоа $ОК 


Ттпр Токеп 5$егусе 


де{РизНТокеп(сйепва, +тр-{®юкеп) | 


срескТтрТокеп(тр-{®юкеп) 


| 
| 
| 
| 
| 
| ыы зай # ны аи на [] 
| 
| 


НЕ) ННГоаа"" 


[уп Киоге 


Как мы 
интегрировали 
пуши Ки5юге 
в Почту Май.ги 


Процесс интеграции ю 
в Почту Ман.ги 


НЕ) ННГоаа"" 


Процесс интеграции 
в Почту Ман.ги 


Начали отправлять 
пуши через Ки юге 
параллельно ЕСМ 


НЕ.) НЕНьоаа** 


Процесс интеграции 


в Почту Ман.ги 


Начали отправлять 
пуши через Ки юге 
параллельно ЕСМ 


Замеряли количество 
доставленных пушей 
за час 


(но) НБИГоаЯ 


Процесс интеграции 


в Почту Ман.ги 


Начали отправлять 
пуши через Ки юге 
параллельно ЕСМ 


Замеряли количество 
доставленных пушей 
за час 


Чинили баги в сервисе 
пушей и аналитике 


ме 


Процесс интеграции 
в Почту Ман.ги 


© © о 

Начали отправлять Замеряли количество Чинили баги в сервисе 
пуши через ВиЗюге а ны пушей и аналитике 
параллельно ЕСМ | 

® 


Будем показывать 
тот пуш, который пришел 
раньше 


фе 


Процесс интеграции 
в Почту Ман.ги 


© © о 

Начали отправлять Замеряли количество Чинили баги в сервисе 
пуши через ВиЗюге а ны пушей и аналитике 
параллельно ЕСМ | 

® о 


Будем показывать 


й Будем замерять 
тот пуш, который пришел 
задержку доставки 
раньше ра 


(но) ННГоаа"" 


Процесс интеграции 
в Почту Ман.ги 


® о 

Начали отправлять Замеряли количество 
пуши через КиЗ®юге доставленных пушей 
параллельно ЕСМ за час 

® о 


Будем показывать 
тот пуш, который пришел 
раньше 


Будем замерять 
задержку доставки 


Чинили баги в сервисе 
пушей и аналитике 


б 
Будем снижать задержку 
доставки 


(но) НЕЕНГоаа** 


Сложность интеграции 


НЕ) ННГоаа"" 


Сложность интеграции 


Для включения пушей 
нужно сделать пару 
Кликов В КОНСОЛИ 
разработчика КиЗоге 


Сложность интеграции 


Для включения пушей Интерфейс нашего ЗОК 


нужно сделать пару повторяет интерфейс 
КЛИКОВ В КОНСОЛИ ОК ЕСМ 


разработчика КиЗоге 


пень 


Сложность интеграции 


Для включения пушей 
нужно сделать пару 
Кликов В КОНСОЛИ 
разработчика КиЗоге 


Интерфейс нашего ОК 
повторяет интерфейс 
ОК ЕСМ 


АРГ отправки пуша 
является агор-п 
гер1асетеп{ для АРГЕСМ 


фе 


Польза от интеграции 


НЕ) ННГоаа"" 


Польза от интеграции 


Защищены на случай, 
если Сооде заблокирует 
нам пуши 


(но) ННЕоаа"" 


Польза от интеграции 


Защищены на случай, 
если Сооде заблокирует 
нам пуши 


Можем повышать 
дейуегу га{е за счет 
отправки по двум 
канала параллельно 


фе 


Польза от интеграции 


Защищены на случай, 
если Сооде заблокирует 
нам пуши 


Можем повышать 
дейуегу га{е за счет 
отправки по двум 
канала параллельно 


Провели нагрузочное 
тестирование пушей 
Ки оге в реальных 
условиях 


(но) ННГоаа"" 


Промежуточные результаты ю 
(УКРМ$ у$ ЕСМ) 


НЕ) ННГоаа"" 


Промежуточные результаты 
(УКРМ$ у$ ЕСМ) 


Количество успешно 
отправленных пушей за 
сутки: -99.999% \м$ 
99.993% 


НЕ) НЕНГоаа 


Промежуточные результаты 
(УКРМ$ у$ ЕСМ) 


о ©® 

Количество успешно Среднее время ответа 
отправленных пушей за АР! зепа: 13тз$ \$ 45т5 
сутки: -99.999% \м$ 

99.993% 


НЕ) НЕНГоаа 


Промежуточные результаты 
(УКРМ$ у$ ЕСМ) 


о о © 

Количество успешно Среднее время ответа Доставляемость пушей 
отправленных пушей за АР! $епа: 13$ \$ 45т$ за сутки: -60% \$ 100% 
сутки: -99.999% \м$ 

99.993% 


Планы на будущее 1 


НЕ) ННГоаа"" 


Планы на будущее 


Приблизиться по 
функциональности кЕСМ 
(рассылки по топикам, 
больше настроек пуша, 
показывать метрики 
доставляемости) 


фе 


Планы на будущее 


Приблизиться по 
функциональности кЕСМ 
(рассылки по топикам, 
больше настроек пуша, 
показывать метрики 
доставляемости) 


Научиться получать 
пуши через другие 
приложения ВК на 
устройстве 
пользователя 


(но) ННЕоаа"" 


Планы на будущее 


Приблизиться по 
функциональности кЕСМ 
(рассылки по топикам, 
больше настроек пуша, 
показывать метрики 
доставляемости) 


Научиться получать 
пуши через другие 
приложения ВК на 
устройстве 
пользователя 


® 

Добиться значения 
Неа А-метрик не хуже, 
чем у Сооде ЕСМ 


(но) ННЕоаа"" 
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